8

1

2

1

2

3

1

2

3

4

5

1

2

3

4

1

2

3

## **CLAIMS**

## What is claimed is:

| `\             |                     |
|----------------|---------------------|
| 2003 .         | $\sum_{\mathbf{l}}$ |
| K <sub>3</sub> | /2                  |
|                | 3                   |
|                | 4                   |
|                | 5                   |
| -              | 6                   |
|                | 7                   |

A processor comprising:
 a replay queue to receive a plurality of instructions;

an execution unit to execute the plurality of instructions;

a scheduler coupled between the replay queue and the execution unit to speculatively schedule instructions for execution; and

a checker coupled to the execution unit to determine whether each instruction of the plurality of instructions has executed successfully, and coupled to the replay queue to dispatch to the replay queue each instruction that has not executed successfully.

- 2. The processor of claim 1 further comprising:
  an allocator/renamer coupled to the replay queue to allocate and rename
  those of a plurality of resources needed by the instruction.
- 3. The processor of claim 2 further comprising:
  a front end coupled to the allocator/renamer to provide the plurality of instructions to the allocator/renamer.
  - 4. The processor of claim 2 further comprising:
    a retire unit to retire the plurality of instructions, coupled to the checker to receive those of the plurality of instructions that have executed successfully, and coupled to the allocator/renamer to communicate a de-allocate signal to the allocator/renamer.
- 5. The processor of claim 4 wherein the retire unit is further coupled to the replay queue to communicate a retire signal when one of the plurality of instructions is retired such that the retired instruction and a plurality of associated data are removed from the replay queue.
  - 6. The processor of claim 1 further comprising: at least one cache system on a die of the processor; a plurality of external memory devices; and

|                         | 4 | a memory request controller coupled to the execution unit to obtain a                       |  |  |
|-------------------------|---|---------------------------------------------------------------------------------------------|--|--|
| Λ.                      | 5 | plurality of data from the at least one cache system and the plurality of external          |  |  |
| <i>አ</i> ን              | 6 | memory devices and to provide the plurality of data to the execution unit.                  |  |  |
|                         | 1 | 7. The processor of claim 6 wherein the at least one cache system comprises                 |  |  |
|                         | 2 | a first level cache system and a second level cache system.                                 |  |  |
|                         | _ |                                                                                             |  |  |
|                         | 1 | 8. The processor of claim 6 wherein the external memory devices comprise at                 |  |  |
|                         | 2 | least one of a third level cache system, a main memory, and a disk memory.                  |  |  |
|                         |   |                                                                                             |  |  |
|                         | 1 | 9. The processor of claim 1 further comprising:                                             |  |  |
|                         | 2 | a staging queue coupled between the checker and the scheduler.                              |  |  |
| 177                     |   |                                                                                             |  |  |
| ngynssys <u>aan</u> enn | 1 | 10. The processor of claim 1 wherein the checker comprises a scoreboard to                  |  |  |
|                         | 2 | maintain a status of a plurality of resources.                                              |  |  |
|                         |   |                                                                                             |  |  |
|                         | 1 | 11. A processor comprising:                                                                 |  |  |
|                         | 2 | a replay queue to receive a plurality of instructions;                                      |  |  |
|                         | 3 | at least two execution units to execute the plurality of instructions;                      |  |  |
|                         | 4 | at least two schedulers coupled between the replay queue and the execution                  |  |  |
|                         | 5 | units to schedule instructions for execution based on data dependencies and                 |  |  |
| u                       | 6 | instruction latencies; and                                                                  |  |  |
|                         | 7 | a checker coupled to the execution units to determine whether each                          |  |  |
|                         | 8 | instruction has executed successfully, and coupled to the replay queue to communicate each  |  |  |
|                         | 9 | instruction that has not executed successfully.                                             |  |  |
|                         | 1 | 12. The processor of claim 11 further comprising:                                           |  |  |
|                         | 2 | a plurality of memory devices coupled to the execution units such that the                  |  |  |
|                         | 3 | checker determines whether the instruction has executed successfully based on a plurality o |  |  |
|                         | 4 | information provided by the memory devices.                                                 |  |  |
|                         | 1 | 13. The processor of claim 12 further comprising:                                           |  |  |
|                         | 2 | an allocator/renamer coupled to the replay queue to allocate and rename                     |  |  |
|                         | 3 | those of a plurality of resources needed by the plurality of instructions.                  |  |  |
|                         | i | 14. The processor of claim 13 further comprising:                                           |  |  |
|                         | 2 | a front end coupled to the allocator/renamer to provide the plurality of                    |  |  |
|                         | 3 | instructions to the allocator/renamer.                                                      |  |  |
|                         |   | 042390.P9577 17 Express Mail No.: EL634500982US                                             |  |  |
|                         |   |                                                                                             |  |  |

|             | 1  | 15.                                                                                           | The processor of claim 13 further comprising:                                    |  |  |
|-------------|----|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--|--|
|             | 2  |                                                                                               | a retire unit to retire the plurality of instructions, coupled to the checker to |  |  |
|             | 3  | receiv                                                                                        | re those of the plurality of instructions that have executed successfully, and   |  |  |
|             | 4  | couple                                                                                        | ed to the allocator/renamer to communicate a de-allocate signal to the           |  |  |
|             | 5  | alloca                                                                                        | tor/renamer.                                                                     |  |  |
|             | 1  | 16.                                                                                           | The processor of claim 15 wherein the retire unit is further coupled to the      |  |  |
|             | 2  | replay queue                                                                                  | to communicate a retire signal when one of the plurality of instructions is      |  |  |
|             | 3  | retired such that the retired instruction and a plurality of associated data are removed from |                                                                                  |  |  |
|             | 4  | the replay que                                                                                | eue.                                                                             |  |  |
|             | 1  | 17.                                                                                           | A method comprising:                                                             |  |  |
|             | 2  |                                                                                               | receiving an instruction of a plurality of instructions;                         |  |  |
| Ō           | 3  |                                                                                               | placing the instruction in a queue with other instructions of the plurality of   |  |  |
|             | 4  | instru                                                                                        | ctions;                                                                          |  |  |
| П           | 5  |                                                                                               | speculatively re-ordering those of the plurality of instructions in a scheduler  |  |  |
| 71          | 6  | based                                                                                         | on data dependencies and instruction latencies;                                  |  |  |
| ij          | 7  |                                                                                               | dispatching one of the plurality of instructions to an execution unit to be      |  |  |
|             | 8  | execu                                                                                         | ted;                                                                             |  |  |
|             | 9  |                                                                                               | executing the instruction;                                                       |  |  |
|             | 10 |                                                                                               | determining whether the instruction executed successfully;                       |  |  |
| U<br>D      | 11 |                                                                                               | routing the instruction back to the queue if the instruction did not execute     |  |  |
| <b>=</b> 12 | 12 | succes                                                                                        | ssfully; and                                                                     |  |  |
|             | 13 |                                                                                               | retiring the instruction if the instruction executed successfully.               |  |  |
|             | 1  | 18.                                                                                           | The method of Claim 17 further comprising:                                       |  |  |
|             | 2  |                                                                                               | allocating those of a plurality of system resources needed by the instruction.   |  |  |
|             | 1  | 19.                                                                                           | The method of Claim 18 wherein retiring comprises:                               |  |  |
|             | 2  |                                                                                               | de-allocating those of the plurality of system resources used by the             |  |  |
|             | 3  | instruction being retired;                                                                    |                                                                                  |  |  |
|             | 4  |                                                                                               | removing the instruction and a plurality of related data from the queue.         |  |  |
|             | 5  |                                                                                               |                                                                                  |  |  |
|             |    |                                                                                               | •                                                                                |  |  |